|
Big Memory is software and hardware approach that facilitates storing/retrieval/processing of large data sets (terabytes and higher). The term is akin to Big Data and in some instances is a form of Big Data processing architecture implemented in memory rather than in disks/storage. Different Caches are one of the usage of the Big Memory. The computer memory, namely RAM works orders of magnitude faster than spinning disks or even Solid State Drives. This is usually due to higher raw data throughput because of tighter coupling of CPU and RAM chips (wider bus, CPU and RAM are usually installed on the same motherboard). Locality of reference is another important characteristic for caches and fast access. The price of the computer memory chips has significantly declined in the late 2000s. As of 2015 it is affordable to have 256 gigabytes of RAM on a server. 〔128 Gb ram chip on NewEgg - http://www.newegg.com/Product/Product.aspx?Item=9SIA7S634M7975〕 Currently, not many vendors have solid software Big Memory solutions while there are plentiful hardware options (i.e. cheap RAM planks). Terracotta has developed a "in-memory data management suite" 〔Terracotta, Inc. - http://terracotta.org/products/bigmemorymax〕 The contemporary software platforms that are based on a garbage collected models, such as .NET CLR , JAVA and others can not usually store hundreds of millions resident objects (object staying in RAM for minutes+ and get promoted to older generations) directly as this results in GC stalls that significantly affect the performance.〔Understanding GC pauses in JVM, HotSpot's minor GC. - http://blog.ragozin.info/2011/06/understanding-gc-pauses-in-jvm-hotspots.html〕 〔Long GC pauses in application - http://stackoverflow.com/questions/15696585/long-gc-pauses-in-application〕 As of 2015 there are still no efficient simple GC solutions that would have allowed to store 16Gb+ object in a language-native-heaps so there are hybrid approaches emerging for memory-hungry apps in the managed environments. NFX Unistack framework provides a concept of a large managed memory 'Pile' on a .NET CLR platform based on pre-allocated large byte[] that do not slow GC down.〔NFX GitHub Inc. - http://github.com/aumcode/nfx〕 The solution allows to easily store 300,000,000 business objects on a machine with 64 Gb RAM while allowing for millions object put/get transactions a second. The solution was purposely provided for processing Big Memory data sets without going to disk/network.〔About Managed Object Pile - https://www.youtube.com/watch?v=WFA1XirINB0〕 〔.NET Heap with hundreds of millions of objects - https://www.youtube.com/watch?v=Dz_7hukyejQ〕 〔Big Memory in .NET 1 - http://www.infoq.com/articles/Big-Memory-Part-1〕 〔Big Memory in .NET 2 - http://www.infoq.com/articles/Big-Memory-Part-2〕 ==References== 抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)』 ■ウィキペディアで「Big Memory」の詳細全文を読む スポンサード リンク
|